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PROVIDING AN EMBEDDED 
APPLICATION SPECIFIC WEB SERVER 



BACKGROUND OF THE INVENTION 

1. Field of the Invention 

The present invention pertains to embedded web access functionality. 
More particularly, this invention relates to providing an embedded web server 
that is based on or configured specifically for web applications run on a device 
with limited computing and storage resources such that the web server is 
application-specific and is small enough to be embedded and run on the device. 

2. Description of the Related Art 

An Internet network system typically includes an Intemet Service 
Provider (ISP) system and an interconnect network that connects the ISP system 
with remote user terminals and other ISP systems. An ISP system typically 
includes a web server that utilizes Intemet applications, such as electronic mail, 
bulletin boards, news groups, and World Wide Web access, to provide data 
accesses and services to users via their user terminals. Each of the user 
terminals includes a web browser that allows the user to access the contents 
hosted in the web servers of the ISP systems. 

The rapid growth of the Intemet, widespread use of the World Wide 
Web, and a trend toward deployment of broadband residential networks have 
led to the development of embedding the web server into electrical and 
electronic devices such as home appliances (e.g., washing machine), peripheral 
devices (e.g., scanner and printer) of a computer system, and measurement 
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instruments (e.g., blood pressure analyzer). This means that a web server can be 
either implemented in one or several physically separate computer systems, or 
embedded within an electrical or electronic device. 

The embedded web server can be implemented in software form. It is 

5 therefore desirable to develop a generic web server that can be embedded in 
various devices. However, problems typically arise when developing such a 
generic web server. One problem is that different computer systems and/or 
electronic devices have their processing resources conformed to different 
hardware architectures (referred to as hardware platforms for software 

10 execution). Each architecture is usually defined by a particular instruction set, 
hardware register set, and memory arrangement, etc. Software written or 
compiled to be executed on a particular hardware platform (i.e., native code) 
usually does not run on other non-compatible hardware platforms. This means 
that a web server for a particular hardware platform is typically only suitable for 

15 devices of that platform. 

One prior solution to tliis problem is to provide a virtual machine for the 
generic web server. The virtual machine enables the generic web server to 
execute on a variety of differing hardware device platform. As is known, the 
software programs executing under such a virtual machine usually take the form 

20 of a stream of instructions, each of which conforms to a predefined instruction 
set supported by the virtual machine. The virtual machine then either interprets 
each of the instructions in the stream and provides emulation of the instructions 
in the native code of the particular hardware platform, or generates native code 
version of the software programs of the particular hardware platform. 

25 Figure 1 shows that prior solution. As can be seen from Figure 1, the 
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device 10 includes a device platform 1 1, a virtual machine 12, an embedded 
web server 13, and web application programs 14. The device platform 1 1 
includes hardware 1 lb and native codes 11a, The native codes 1 la typically 
include device hardware-specific system programs (e.g., device operating 

5 systems) that (1) manage the resources of the device 10 and (2) execute other 
application programs in native code. The virtual machine 12 runs on top of the 
native codes 11a. The web server 13 is a generic web server. The web 
applications 14 are functional extensions of the web server 13. The virtual 
machine 12 enables the embedded generic web server 13 and the web 

10 apphcations 14 to execute on a variety of differing hardware/device platforms. 

However, disadvantages are still associated with the prior solution shown 
in Figure 1 . One disadvantage is that the virtual machine typically significantly 
increases the size of the embedded web server since the embedded web server 
structure now needs to include both the web server and the virtual machine. In 

15 addition, the size of the virtual machine is also relatively large. This is due to 
the fact that the virtual machine needs to be applicable to a large variety of web 
applications. To achieve this, the virtual machine needs to contain codes for 
different web applications, even though these web applications may not be 
running in the device. Unfortunately, this one-size-fits-all virtual machine 

20 typically causes the web server structure to consume large amounts of resources 
such as memory and processor cycles and are therefore not well suited for 
devices having relatively limited resources. 

Thus, there is a need to develop a web server structure that requires 
minimized storage space when embedded in a device. 
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SUMMARY OF THE INVENTION 

One feature of the present invention is to embed a web server in a device 
w^ith limited computing and storage resources. 
5 Another feature of the present invention is to configure an embedded web 

server such that it only requires minimized storage space when embedded in a 
device. 

A fiirther feature of the present invention is to provide an embedded web 
server based on the web applications run on the device. 
10 A still further feature of the present invention is to provide a compiler that 

configures an embedded web server based on the web applications run on the 
device. 

A method of providing an embedded web server for a device is described. 
The device is required to run a web application. The method includes the step 

15 of providing a web server class library and a virtual machine class library. The 
web server class library and the virtual machine class library include classes 
suitable for different web applications. The method also includes the step of 
identifying a particular web appHcation to be run on the device. The libraries 
and the web application are then passed through a compiler to select from the 

20 web server class library and the virtual machine class library classes required to 
run the web application in the device to form the web server. This makes the 
web server an application-specific web server which requires minimized storage 
space from the device when embedded in the device. 

A system for providing a web server for a device is also described. The 

25 device is required to run a web application. The system includes a web server 
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class library and a virtual machine class library. Each of the class libraries 
includes classes for different web applications. The system also includes a 
compiler that receives the libraries and the web application to select from the 
web server class library and the virtual machine class library classes required to 
5 run the web application in the device to form the web server such that the web 
server is an application-specific web server and requires rninimized storage 
space when embedded in the device. 

A web server structure for a device having a device platform is also 
described. The web server structure includes a web application that performs a 

O 10 predetermined web function. The web server structure also includes an 

application-specific web server core and an application-specific virtual machine 

O that together execute the web application on the device. The application- 

specific web server core and virtual machine are specifically configured for the 

- web application such that they require minimized storage space when embedded 

1^ 15 in the device. 

1=^ Other features and advantages of the present invention will become 

ci apparent from the following detailed description, taken in conjunction with the 

accompanying drawings, illustrating by way of example the principles of the 

invention. 
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BRIEF DESCRIPTION OF THE DRAWINGS 



Figure 1 shows a prior art arrangement of an embedded web server 
5 structure for a device. 

Figure 2 shows an application-specific embedded web server structure for 
a device in accordance with one embodiment of the present invention. 

Figure 3 shows the compiler that generates the application-specific 
embedded web server stmcture in accordance with one embodiment of the 
10 present invention. 

Figure 4 shows in flow chart diagram form the process of the compiler of 
Figure 3 in generating the application-specific embedded web server structure of 
Figure 2, 

Figure 5 illustrates the operation of the compiler of Figure 3 in generating 
15 the application-specific embedded web server structure of Figure 2. 
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DETAILED DESCRIPTION OF THE INVENTION 



Figure 2 shows a device 20 with a web server structure 22 that 
implements one embodiment of the present invention. The web server structure 

5 22 enables a web application 23 to execute on a device platform 21 of the 

device 20. The web server structure 22 is embedded in the device 20. This can 
be accomplished, for example, by storing the web server structure 22 in a 
memory or storage of hardware 21b of the device 20 when the web server 
structure 22 is implemented in software form. 

10 Li accordance with one embodiment of the present invention, the web 

server stmcture 22 is specifically configured or tuned to execute the web 
application 23 on the device platform 21 of the device 20 such that the web 
server structure 22 is an application-specific web server structure which requires 
minimized storage space when embedded in the device 20. This allows the web 

15 server structure 22 to be embedded in a device with limited storage resources. 

As will be described in more detail below, the application-specific web 
server structure 22 enables (i.e., provides a runtime environment for) the web 
application 23 to be executed on the device platform 21 of the device 20. The 
web application 23 performs one or more predetermined web functions. The 

20 application-specific web server structure 22 includes an application-specific web 
server core 24 and an application-specific virtual machine 25. The application- 
specific web server core 24 and the application-specific virtual machine 25 are 
specifically configured or tuned for running the web application 23 such that 
they require minimized storage space when embedded in the device 20. In 

25 addition, the application-specific web server core 24 and the application-specific 
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virtual machine 25 are specifically tuned (in terms of the class files required) to 
run the web application 23. 

The application-specific web server core 24 and the application-specific 
virtual machine 25 are both configured by a web server compiler 30 (Figure 3). 

5 The web server compiler 30 generates the application-specific web server core 
24 firom a web server class library 3 1 (shown in Figure 3). The web server class 
library 31 includes all web server class files needed to run various web 
applications, including the web application 23. The web server compiler 30 also 
generates the appUcation-specific virtual machine 25 from a virtual machine 

10 class library 32 (shown in Figure 3). The virtual machine class library 32 

includes virtual machine class files that are required to enable a variety of web 
server classes and web apphcations to execute on the device platform 21 of the 
device 20. This allows the web server structure 22 to only require minimized 
storage space when being embedded in the device 20. In addition, this also 

15 allows the application-specific web server structure 22 to be specifically tuned 
(in terms of the class files required) to run the web application 23. The 
application-specific web server structure 22 and the web server compiler 30 will 
be described in more detail below, also in conjunction with Figures 2-5, 
Referring to Figure 2, the device 20 can be any kind of electrical or 

20 electronic device such as a computer peripheral device (e.g., a printer, a fax 
machine, a copier, a scanner), a communication device, a television, a video 
player, an audio player, a home appliance (e.g., refiigerator or dish washer), a 
medical device (e.g., a blood pressure analyzer or a patient monitoring device), 
hi addition, the device 20 can be a computer-based device such as a personal 

25 computer, a notebook computer, a palm-top computer, a mini-computer, or any 
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other computer systems. 

As described above, the device 20 includes the device platform 21. The 
device platform 21 of the device 20 includes the hardware 21b and native codes 
21a. The hardware 21b includes processing and memory/storage resources. 
5 The processing and memory resources of the hardware 21b conform to a 

particular known architecture, which is defined by instruction set, hardware 
register set, and memory arrangement, etc. The particular architecture can also 
be referred to as a hardware platform for software execution. The construction 
of the hardware 21b depends on the type of the device 20 and the functions the 

10 device 20 provides. 

The native codes 21a are executed on the hardware 21b. The native 
codes 21a are written or compiled to be executed on the particular hardware 
platform of the hardware 21b. The native codes 21a typically include hardware- 
specific system programs (e.g., device operating systems) that (1) manage the 

15 resources of the hardware 21b of the device 20 and (2) execute other application 
programs in native code. The native codes 21a can be implemented using any 
known means. The construction of the native codes 21a, however, depends on 
the particular hardware platform of the hardware 21b. The native codes 21a and 
hardware 21b together form the device platform 21 of the device 20. 

20 As can be seen fi*om Figure 2, the device 20 also includes the application- 

specific web server structure 22. The web server structure 22 is configured on 
top of the device platform 21 . The web server structure 22 allows the device 20 
to be universally accessible by web clients (not shown) connected to the device 
20 via cormnunication networks (not shown). The networks are capable of 

25 carrying Intemet/Intranet communications. A web client can be a web browser 
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in a computer system. It can also aaother web server embedded in another 
device. The web chent accesses the web server structure 22 of the device 20 
using an open standard communication protocol (e.g., HTTP). The HTTP 
protocol is used to transfer multiple information encodings between network 
5 elements. 

The web server structure 22 exchanges messages with the web clients 
using the HTTP protocol. The web server structure 22 receives HTTP 
conmiands or requests from the web clients. The HTTP commands specify one 
of a set of predetermined URLs for the device 20, The web server structure 22 
10 is accessed by a unique URL for the device 20. When the device 20 supports 

multiple resources, the web server structure 22 includes resource URLs to allow 
accesses to those resources. Thus, the URLs for the device 20 specify the web 
pages and application and control programs associated with the web server 
structure 22. 

15 The HTTP cormnands or requests are used by the web clients to obtain 

information from the device 20, or to invoke some control or appUcation 
programs in the device to perform some fimctions. In addition, HTTP 
commands are generated in the device 20 to perform file transfers, and to obtain 
new information and software codes for loading into the device 20 and for 

20 updating software codes. 

The web server structure 22 also enables the web apphcation 23 to run on 
the device platform 21 . The web server structure 22 is an apphcation-specific 
web server structure based on the web application 23. This means that the web 
server structure 22 is specifically configured for the web application 23. In 

25 other words, the web server structure 22 provides a runtime environment 
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specifically tuned to run the web application 23. This allows the web server 
structure 22 to be small in size and requires minimized space to store. 

The web appUcation 23 is run on top of the web server structure 22. The 
web apphcation 23 is a functional extension of the web server structure 22, The 

5 web application 23 performs one or more predetermined web-related functions. 
The web application 23 can be any known web application. Alternatively, the 
web apphcation 23 includes a number of known web applications. When this is 
the case, the application-specific web server structure 22 is specifically 
configured to all of the web applications. 

10 In one embodiment, the web server structure 22 is implemented by 

software. Altematively, the web server structure 22 can be implemented in 
other forms. For example, the web server structure 22 can be implemented by 
firmware. 

The web server structure 22 and the web application 23 are embedded in 
15 the device 20. This means that when the web server structure 22 is implemented 
by software, the web server structure 22 and the web application 23 are stored 
in the storage of the hardware 21b of the device 20. The web server stmcture 
22 and the web application 23 can also be embedded in the device 20 by other 
means (e,g., firmware). 
20 The web server stmcture 22 includes the apphcation-specific web server 

core 24 and the application-specific virtual machine 25, The web server core 24 
provides the basic web server fimctions to the device 20. In addition, the web 
server core 24 allows the web application 23 to provide additional web 
fimctions to the device 20. The web server core 24 is an application-specific 
25 web server core that is based on the web application 23. This means that the 
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web server core 24 is specifically configured to provide a runtime environment 
specifically tuned to run the web application 23. 

The web server core 24 runs on the application-specific virtual machine 
25 which in turn runs on the native codes 21a. The virtual machine 25 provides 
5 logical abstraction of the underlying physical system (i.e., device platform 21) of 
the device 20 to the web server core 24. This means that the virtual machine 25 
provides an execution environment for the web server core 24 and the web 
application 23. The main fimction of the virtual machine 25 is to enable the web 
server core 24 and the web appUcation 23 to execute on the device platform 21 
10 of the device 20. Here, the low level interpreter of the virtual machine 25 and 

the native codes 21a necessary to access the system hardware have already been 
written for the particular hardware platform of the hardware 21b of the device 
20. This means that the virtual machine 25 is also a device-specific virtual 
machine. 

15 The virtual machine 25 is also an application-specific virtual machine that 

is based on the web application 23. This means that the virtual machine 25 is 
specifically configured to provide a runtime environment specifically tuned to 
run the web appHcation 23 and the application-specific web server core 24 that 
is also based on the web application 23. 

20 As described above, the web server core 24 is an application-specific web 

server core that is based on the web application 23. In addition, the virtual 
machine 25 is also an application-specific virtual machine that is based on the 
web application 23. This causes the web server structure 22 which includes the 
web server core 24 and the virtual machine 25 to be minimal in size and requires 

25 minimized storage resources when embedded in the device 20. This in tum 
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causes the device 20 to be of a device with limited resources. This also means 
that both the web server core 24 and the virtual machine 25 are specifically 
tuned to provide a runtime environment for running the web application 23 in 
terms of class files required. 
5 Both of the appUcation-specific web server core 24 and the application- 

specific virtual machine 25 are generated by a web server compiler 30 (shown in 
Figure 3). The web server compiler 30 generates the application-specific web 
server core 24 from a web server class library 31 and the appUcation-specific 
virtual machine 25 from a virtual machine class library 32 (both shown in Figure 
10 3). Figure 3 shows the process of configuring the two modules (i.e., 24 and 25) 
using the web server compiler 30, which will be described in more detail below. 
Figure 4 shows the process of the web server compiler 30 in parsing (1) the web 
server class hbrary 31 to configure the application-specific web server core 24 
based on the web application 23, or (2) the virtual machine class library 32 to 
15 configure the apphcation-specific virtual machine 25 based on the web 
apphcation 23 . Figure 4 will also be described in more detail below. 

Referring to Figure 3, the web server compiler 30 receives the web 
apphcation 23, the web server class hbrary 31, and the virtual machine class 
library 32 to configure the application-specific web server core 24 and the 
20 application-specific virtual machine 25 based on the web application 23. As 

described above, the web server core 24 is configured from the web server class 
library 31 and the virtual machine 25 is configured from the virtual machine 
class library 32. The web server class library 3 1 includes all the web server 
class files that are required to run all the known web applications. This means 
25 that the library 3 1 is a complete collection of web server class files required to 
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run any known web application. The virtual machine class library 32 includes 
all the virtual machine class files that are required to run all the known web 
applications and web server class files. This means that the library 32 is a 
complete collection of virtual machine class files required to run any known web 

5 apphcation and web server. Here, the low level interpreter of the virtual 

machine class library 32 necessary to access the system hardware and native 
codes has already been written for the particular device platform 21 of the 
device 20. This means that the virtual machine class Ubrary 32 is also a device- 
specific virtual machine class library. 

10 The class files in each of the libraries 3 1-32 define objects that implement 

the web server or virtual machine. The file definition for each class file in each 
of the libraries 31-32 is standard and interpreted. In addition, class 
dependancies between class files in each of the class libraries 31-32 can easily 
be determined by parsing the class file definition of a class file. Given the 

15 above, it is now possible for the compiler 30 to automatically parse the class 
files of each of the libraries 31-32 to create the apphcation-specific web server 
core 24 and the application-specific virtual machine 25 that are specifically 
tuned (in terms of classes required) to run the web application 23. Figure 4 
shows the parsing operation of the compiler 30, which will be described in more 

20 detail below. 

Figure 4 shows in flow chart diagram form the process of parsing (1) the 
web server class library 31 to configure the application-specific web server core 
24 based on the web apphcation 23, or (2) the virtual machine class library 32 to 
configure the apphcation-specific virtual machine 25 based on the web 

25 apphcation 23 by the web server compiler in accordance with one embodiment 
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of the present invention. As can be seen from Figures 2-4, the process starts at 
the step 40. At the step 41, a class required to run the web application 23 is 
identified from a class library (i.e., either library 31 or 32). Then the next step 
42 is performed to determine if the required class is a base class. This can be 
5 done by looking at the imports field of the class file of the required class (see the 
class file 62 or 63 in Figure 5). If flie imports field of the class file does not 
point to other classes, then the required class is a base class. This means that 
executing the required class does not require other classes. If the imports field 
of the class file of the required class points to other classes, then the required 
10 class is not a base class (i.e., execution of the required class requires the 
execution of these other classes). 

If the required class is determined not to be a base class at the step 42, 
then the step 43 is performed at wliich the compiler 30 exfracts from the imports 
list of the class file of the requhed class (e.g., the import hst of the class file 60 
15 in Figure 5) the other classes (e.g., the classes B and C in Figure 5) that are 
Hsted as required to run the required class. The compiler 30 then marks the 
other classes as required classes at the step 44. The compiler 30 then selects 
another required class from the other required classes at the step 45. The 
process then moves back to the step 42. 
20 If, at tiie step 42, it is determined that the required class is a base class, 

then the step 47 is performed, at which it is determined whether there are other 
unchecked required classes. If so, the process moves to the step 45. If not, the 
process moves to the step 48 at which the class files of all the required classes 
are collected to form the application-specific web server 24 or virtual machine 
25 25. The process then ends on the step 49. 
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The following shows a specific example of the web server structure 22 in 
Figure 2 configured by the web server compiler 30 of Figure 3 in accordance 
with one embodiment of the present invention. In this example, the particular 
web appUcation 23 is the knovm Web-link application. The Web-link 
5 application is a Java web-based application used to support mobile web sites. 
The Web-link apphcation is constructed as a set of Java Classes and requires 
48.8KBytes space to store. 

In this case, the apphcation-specific web server core 24 is an appHcation- 
specific SmallWeb web server which is derived from a knovm SmallWeb web 
10 server class library (available from Hewlett-Packard Company of Palo Alto, 
California). The SmallWeb class library has a size of 230KBytes. The 
application-specific virtual machine 25 is an apphcation-specific Java virtual 
machine which is also derived from a known Java virtual machine (for Win32) 
class library (also available from Hewlett-Packard Company of Palo Alto, 
15 California). The Java virtual machine class library includes a Java interpreter 
and a Java class library. The Java virtual machine class library requires 
8.98MBytes storage space. The total size for the entire system (including the 
Web-link application) will be more than 9Mbytes, which is obviously far too 
large to fit in any device with limited storage resources. In addition, this size is 
20 also far too large to fit on a 1 .44MBytes floppy disk. 

After passing the Java virtual machine class library, the SmallWeb class 
library, and the Web-link application through the web server compiler 30 
(Figure 3) of the present invention, the apphcation-specific SmallWeb web 
server and the apphcation-specific Java virtual machine are generated. The 
25 SmallWeb web server which is specifically configured for the Web-link 
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application only has a size of 178KBytes. Likewise, the Java virtual machine 
which is specifically configured for the Web-link appHcation only requires a 
storage space of 914KBytes. hi this case, the total size of the entire system 
(including the Web-link apphcation) is only a bit over IMBytes, which can 
5 easily be stored on a 1 .44MBytes floppy disk with space to spare. 

From the above example, it is clear that the size of virtual machine can be 
significantly tuned based on its usage of the underlying web applications. 

In the foregoing specification, the invention has been described with 
reference to specific embodiments thereof It will, however, be evident to those 
10 skilled in the art that various modifications and changes may be made thereto 
without departing from the broader spirit and scope of the invention. The 
specification and drawings are, accordingly, to be regarded in an illustrative 
rather than a restrictive sense. 
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CLAIMS 



What is claimed is: 

1 . A method of providing an embedded web server for a device, 
comprising the steps of: 

(A) providing a web server class library and a virtual machine class 
library, wherein the web server class library and the virtual machine class library 
include classes for different web applications; 

(B) identifying a particular web application to be run on the device; 

(C) compiling the web server by selecting from the web server class 
library and the virtual machine class library classes required to run the web 
application in the device to form the web server, wherein the web server is an 
application-specific web server and requires minimized storage space when 
embedded in the device. 

2. The method of claim 1, wherein the step (C) further comprises the 
step of sending the libraries and the web application through a compiler to select 
the required classes from the libraries, 

3. The method of claim 1, wherein for each of the libraries, the step 
(C) is performed by 

(I) identifying from the library a class required to run the web 
application; 

(II) extracting from the class file of the required class other classes 
required to run the required class; 
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(III) repeating the steps (I) and (II) for each of the required classes until 
the required class is a base class; 

(IV) collecting all the required classes to form the application-specific 
web server. 

4 The method of claim 1, wherein the device is an electronic device 
and the apphcation-specific web server is embedded in the device, 

5. The method of claim 1, wherein the device runs a plurality of web 
applications, including the particular web application, wherein the step (C) 
compiles the web server by selecting fi-om the web server class library and the 
virtual machine class library classes required to run all of the web apphcations in 
the device to form the web server. 

6. A system for providing a web server for a device running a web 
application, comprising: 

(A) a web server class library and a virtual machine class library, each 
including classes for different web applications; 

(B) a compiler that receives the libraries and the web application to 
select from the web server class library and the virtual machine class library 
classes required to run the web apphcation in the device to form the web server 
such that the web server is an apphcation-specific web server and requires 
minimized storage space when embedded in the device. 

7. The system of claim 6, wherein the device is an electronic device 
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and the application-specific web server is embedded in the device. 

8. The system of claim 6, wherein the compiler selects the required 
classes fi*om each of the libraries by 

(I) identifying fi-om the library a class required to run the web 
application; 

(II) extracting from the class file of the required class other classes 
required to run the required class; 

(III) repeating the steps (I) and (II) for each of the required classes until 
the required class is a base class; 

(IV) collecting all the required classes to form the application-specific 
web server. 

9. The system of claim 6, wherein the device runs a plurality of web 
applications, including the particular web application, wherein the compiler 
compiles the web server for running all of the plurality of web applications by 
selecting from the libraries classes required to run all of the plurality of web 
applications. 

10. A web server structure for a device, comprising: 

(A) a web application that performs a predetermined web fimction; 

(B) an application-specific web server core and an application-specific 
virtual machine that together execute the web application on the device, wherein 
the application-specific web server core and the application-specific virtual 
machine are specifically configured for the application such that they require 
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minimized storage space when embedded in the device. 

1 1 . The web server structure of claim 1 0, wherein the device is an 
electronic device and the application-specific web server structure is embedded 
in the device. 

12. The web server structure of claim 10, fiirther comprising a plurality 
of web applications, including the particular web application, wherein the 
application-specific web server core and virtual machine are specifically 
configured to run the applications such that they require minimized storage 
space when embedded in the device. 
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ABSTRACT 



A method of providing an embedded web server for a device is 
described. The device is of a particular device platform and is required to run 
a web apphcation. The method includes the step of providing a web server 
class library and a virtual machine class library. The web server class library 
and the virtual machine class library include classes suitable for different web 
appUcations. The method also includes the step of identifying a particular web 
application to be run on the device. The libraries and the web apphcation are 
then passed through a compiler to select from the web server class library and 
the virtual machine class library classes required to run the web apphcation in 
the device to form the web server. This makes the web server an application- 
specific web server which requires minimized storage space from the device 
when embedded in the device. A system for providing an apphcation-specific 
embedded web server for a device is also described. 
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